const Mock = require('mockjs')

const List = []
const count = 100

const baseContent = '<p>I am testing data, I am testing data.</p><p><img src="https://wpimg.wallstcn.com/4c69009c-0fd4-4153-b112-6cb53d1cf943"></p>'
const image_uri = 'https://wpimg.wallstcn.com/e4558086-631c-425c-9430-56ffb46e70b3'

for (let i = 0; i < count; i++) {
	List.push(
		Mock.mock({
			id: '@increment',
			timestamp: +Mock.Random.date('T'),
			author: '@first',
			reviewer: '@first',
			title: '@title(5, 10)',
			content_short: 'mock data',
			content: baseContent,
			forecast: '@float(0, 100, 2, 2)',
			importance: '@integer(1, 3)',
			'type|1': ['CN', 'US', 'JP', 'EU'],
			'status|1': ['published', 'draft'],
			display_time: '@datetime',
			comment_disabled: true,
			pageviews: '@integer(300, 5000)',
			image_uri,
			platforms: ['a-platform']
		})
	)
}

module.exports = [
	{
		url: '/vue-element-admin/article/list',
		type: 'get',
		response: config => {
			const { importance, type, title, pageIndex = 1, pageSize = 20, sort } = config.query

			let mockList = List.filter(item => {
				if (importance && item.importance !== +importance) return false
				if (type && item.type !== type) return false
				if (title && item.title.indexOf(title) < 0) return false
				return true
			})

			if (sort === '-id') {
				mockList = mockList.reverse()
			}

			const pageList = mockList.filter((item, index) => index < pageSize * pageIndex && index >= pageSize * (pageIndex - 1))

			return {
				code: 20000,
				data: {
					total: mockList.length,
					items: pageList
				}
			}
		}
	},

	{
		url: '/vue-element-admin/article/detail',
		type: 'get',
		response: config => {
			const { id } = config.query
			for (const article of List) {
				if (article.id === +id) {
					return {
						code: 20000,
						data: article
					}
				}
			}
		}
	},

	{
		url: '/vue-element-admin/article/pv',
		type: 'get',
		response: _ => {
			return {
				code: 20000,
				data: {
					pvData: [
						{ key: 'PC', pv: 1024 },
						{ key: 'mobile', pv: 1024 },
						{ key: 'ios', pv: 1024 },
						{ key: 'android', pv: 1024 }
					]
				}
			}
		}
	},

	{
		url: '/vue-element-admin/article/create',
		type: 'post',
		response: _ => {
			return {
				code: 20000,
				data: 'success'
			}
		}
	},

	{
		url: '/vue-element-admin/article/update',
		type: 'post',
		response: _ => {
			return {
				code: 20000,
				data: 'success'
			}
		}
	}
]
